package com.agrimall.mapper;

import com.agrimall.entity.User;
import org.apache.ibatis.annotations.Param;
import java.util.List;

/**
 * 用户Mapper接口
 */
public interface UserMapper {
    /**
     * 根据ID查询用户
     */
    User selectById(Long userId);
    
    /**
     * 根据用户名查询用户
     */
    User selectByUsername(String username);
    
    /**
     * 插入用户
     */
    int insert(User user);
    
    /**
     * 更新用户
     */
    int update(User user);
    
    /**
     * 删除用户
     */
    int delete(Long userId);
    
    /**
     * 查询所有用户（分页）
     */
    List<User> selectAll(@Param("offset") int offset, @Param("limit") int limit);
    
    /**
     * 根据用户类型查询用户列表
     */
    List<User> selectByUserType(@Param("userType") Integer userType, 
                                @Param("offset") int offset, 
                                @Param("limit") int limit);
    
    /**
     * 统计用户总数
     */
    int countAll();
    
    /**
     * 根据用户类型统计数量
     */
    int countByUserType(Integer userType);
    
    /**
     * 根据关键词搜索用户列表
     */
    List<User> selectByKeyword(@Param("keyword") String keyword,
                               @Param("offset") int offset,
                               @Param("limit") int limit);
    
    /**
     * 根据关键词统计用户数量
     */
    int countByKeyword(@Param("keyword") String keyword);
    
    /**
     * 根据用户类型和关键词搜索用户列表
     */
    List<User> selectByTypeAndKeyword(@Param("userType") Integer userType,
                                      @Param("keyword") String keyword,
                                      @Param("offset") int offset,
                                      @Param("limit") int limit);
    
    /**
     * 根据用户类型和关键词统计用户数量
     */
    int countByTypeAndKeyword(@Param("userType") Integer userType,
                              @Param("keyword") String keyword);
}



